package daily.kou2022_0104;

public class Num21 {
    //21. 合并两个有序链表(递归)
//    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
//        //递归终止条件
//        if(list1==null)return list2;
//        if (list2==null)return list1;
//        if(list1.val<= list2.val){
//            list1.next=mergeTwoLists(list1.next,list2);
//            return list1;
//        }else {
//            list2.next=mergeTwoLists(list1,list2.next);
//            return list2;
//        }
//    }
    //21. 合并两个有序链表(迭代)
    public ListNode mergeTwoLists(ListNode list1, ListNode list2) {
                // 边界
        if (list1 == null) {
            return list2;
        }
        if (list2 == null) {
            return list1;
        }
        // 此时l1和l2都不为空
        ListNode dummyHead = new ListNode(101);
        ListNode last = dummyHead;
        while (list1 != null && list2 != null) {
            if (list1.val <= list2.val) {
                last.next = list1;
                last = list1;
                list1 = list1.next;
            }else {
                last.next = list2;
                last = list2;
                list2 = list2.next;
            }
        }
        // 此时l1或l2为空
        if (list1 == null) {
            last.next = list2;
        }else {
            last.next = list1;
        }
        return dummyHead.next;
    }
}
